home *** CD-ROM | disk | FTP | other *** search
/ Skunkware 98 / Skunkware 98.iso / src / mail / pine3.96.tar.gz / pine3.96.tar / pine3.96 / imap / ANSI / c-client / log_sv4.c < prev    next >
C/C++ Source or Header  |  1995-05-01  |  3KB  |  67 lines

  1. /*
  2.  * Program:    SVR4 server login
  3.  *
  4.  * Author:    Mark Crispin
  5.  *        Networks and Distributed Computing
  6.  *        Computing & Communications
  7.  *        University of Washington
  8.  *        Administration Building, AG-44
  9.  *        Seattle, WA  98195
  10.  *        Internet: MRC@CAC.Washington.EDU
  11.  *
  12.  * Date:    11 May 1989
  13.  * Last Edited:    1 May 1995
  14.  *
  15.  * Copyright 1995 by the University of Washington
  16.  *
  17.  *  Permission to use, copy, modify, and distribute this software and its
  18.  * documentation for any purpose and without fee is hereby granted, provided
  19.  * that the above copyright notice appears in all copies and that both the
  20.  * above copyright notice and this permission notice appear in supporting
  21.  * documentation, and that the name of the University of Washington not be
  22.  * used in advertising or publicity pertaining to distribution of the software
  23.  * without specific, written prior permission.  This software is made
  24.  * available "as is", and
  25.  * THE UNIVERSITY OF WASHINGTON DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED,
  26.  * WITH REGARD TO THIS SOFTWARE, INCLUDING WITHOUT LIMITATION ALL IMPLIED
  27.  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, AND IN
  28.  * NO EVENT SHALL THE UNIVERSITY OF WASHINGTON BE LIABLE FOR ANY SPECIAL,
  29.  * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  30.  * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, TORT
  31.  * (INCLUDING NEGLIGENCE) OR STRICT LIABILITY, ARISING OUT OF OR IN CONNECTION
  32.  * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  33.  *
  34.  */
  35.  
  36. /* Server log in
  37.  * Accepts: user name string
  38.  *        password string
  39.  *        optional place to return home directory
  40.  * Returns: T if password validated, NIL otherwise
  41.  */
  42.  
  43. long server_login (char *user,char *pass,char **home,int argc,char *argv[])
  44. {
  45.   char *pwd,tmp[MAILTMPLEN];
  46.   struct spwd *sp = NIL;
  47.   struct passwd *pw = getpwnam (user);
  48.                 /* allow case-independent match */
  49.   if (!pw) pw = getpwnam (lcase (strcpy (tmp,user)));
  50.                 /* no entry for this user or root */
  51.   if (!(pw && pw->pw_uid)) return NIL;
  52.   if ((((*(pwd = pw->pw_passwd) == 'x') && (!pwd[1])) ||
  53.        ((pwd[0] == '#') && (pwd[1] == '#'))) && (sp = getspnam (pw->pw_name)))
  54.     pwd = sp->sp_pwdp;        /* get shadow password if necessary */
  55.                 /* validate password and password age */
  56.   if (strcmp (pwd,(char *) crypt (pass,pwd)) ||
  57.       (sp && (sp->sp_lstchg > 0) && (sp->sp_max > 0) &&
  58.        ((sp->sp_lstchg + sp->sp_max) < (time (0) / (60*60*24)))))
  59.     return NIL;
  60.   setgid (pw->pw_gid);        /* all OK, login in as that user */
  61.   initgroups (pw->pw_name);    /* initialize groups */
  62.   setuid (pw->pw_uid);
  63.                 /* note home directory */
  64.   if (home) *home = cpystr (pw->pw_dir);
  65.   return env_init (pw->pw_name,pw->pw_dir);
  66. }
  67.